Telegram Group & Telegram Channel
إزاي تتعامل مع الـ State في مشاريع الفرونت إند؟ 💡
.
.
خليني أحكيلك سيناريو بسيط:

أنت شغال على UI لتطبيق إعلانات. في الصفحة الرئيسية فيه زرار بيعرض modal، وفي نفس الوقت فيه قائمة إعلانات بترجع من API، ولما تضغط على إعلان بتروح على صفحة التفاصيل.

دلوقتي الـ modal ده لو تحكمت فيه بـ useState مثلًا في نفس الـ component؟ تمام.
بس الإعلانات؟ محتاج تجيبها من API وتخزنها؟ هتضيفها فين؟
ولو صفحة التفاصيل محتاجة تشوف نفس الداتا؟ هتعمل إيه؟
ولو عندك مستخدم مسجل دخول، ومحتاج كل الصفحات تعرف حالته؟

هنا تبدأ قصة الـ State Management، وتحديدًا:

- هل الداتا دي تبقى locally؟
- ولا تكون في global state؟
ولا تفضل على الـ server وتجيبها كل مرة؟

تعال ندردش شوية عن إزاي تتعامل مع الـ State في مشاريع الفرونت إند...

———

أنواع الـ State اللي ممكن تتعامل معاها:

1- Local State

مثل:

- الـ modal مفتوح ولا مقفول
- الـ tab اللي مفتوح
- الفورم فيه error ولا لا

بتستخدم معاه حاجات زي useState, useReducer, أو حتى useRef.

———

2- Global State

ده اللي بيكون مهم لأكثر من component أو حتى أكتر من صفحة.

مثل:

- بيانات المستخدم بعد ما يعمل تسجيل دخول
- اللغة المختارة
- محتوى الـ shopping cart

ممكن تتعامل معاه باستخدام:
Context API | Redux | Zustand | Jotai

———

3- Server State

يعني داتا راجعة من API وبتتغير دايمًا.

مثل:

- قائمة البوستات اللي بترجع
- الإعلانات
- بيانات المنتج

التعامل معاها الأفضل يتم من خلال:

- React Query
- SWR
- custom hooks using fetch

———

4- URL State

ده زي الـ query params والـ path variables.

مثل:

- ?search=react
- /products/123


بتحتاجه لما الصفحة تكون reactive بناءً على URL.

———

💡 إزاي تقرر تستخدم أي نوع منهم؟

اسأل نفسك 3 أسئلة:

1. الداتا دي مين محتاج يشوفها؟

- لو component واحدة تبقى local
- لو أكثر من component أو أكثر من صفحة تبقى global


2. هل الداتا دي راجعة من السيرفر؟

- لو أيوه تبقى server state
- لو لا يبقى ترجع لإجابة السؤال الأول


3. هل محتاج تعمل caching أو refetching؟

- لو أيوه ممكن تستخدم React Query/SWR
- لو لا يبقى الـ useEffect كفاية

———

شوية نصائح من التجربة:

- بلاش تستعجل وتستخدم Redux، كتير بيستخدموه في حاجات صغيرة جدًا ممكن تتحل بـ Context أو حتى props.

- خلي الداتا اللي بتتغير كتير تفضل على السيرفر، وخلي الـ React Query تمسكها بدل ما تعملها global state manually.

- متخليش كل حاجة global، ده بيخلي الـ re-rendering يزيد والـ debugging بيكون أصعب.

- الـ Server State مش دايمًا محتاج يتحول لـ Global State، الـ React Query مثلًا بيخزنها وبيشاركها بين الـ components تلقائي، من غير ما تدخلها في Redux أو غيره.

- الـ Context ممتاز للحاجات اللي مش بتتغير كتير، زي الـ theme أو اللغة أو المستخدم اللي دخل مرة واحدة وخلاص.

———

اختيارك للـ state له تأثير مباشر على الـ performance، وكمان الـ maintainability، والـ DX بتاعك.

———

وفقكم الله لكل خير 🌿



tg-me.com/the_developer_guide/5316
Create:
Last Update:

إزاي تتعامل مع الـ State في مشاريع الفرونت إند؟ 💡
.
.
خليني أحكيلك سيناريو بسيط:

أنت شغال على UI لتطبيق إعلانات. في الصفحة الرئيسية فيه زرار بيعرض modal، وفي نفس الوقت فيه قائمة إعلانات بترجع من API، ولما تضغط على إعلان بتروح على صفحة التفاصيل.

دلوقتي الـ modal ده لو تحكمت فيه بـ useState مثلًا في نفس الـ component؟ تمام.
بس الإعلانات؟ محتاج تجيبها من API وتخزنها؟ هتضيفها فين؟
ولو صفحة التفاصيل محتاجة تشوف نفس الداتا؟ هتعمل إيه؟
ولو عندك مستخدم مسجل دخول، ومحتاج كل الصفحات تعرف حالته؟

هنا تبدأ قصة الـ State Management، وتحديدًا:

- هل الداتا دي تبقى locally؟
- ولا تكون في global state؟
ولا تفضل على الـ server وتجيبها كل مرة؟

تعال ندردش شوية عن إزاي تتعامل مع الـ State في مشاريع الفرونت إند...

———

أنواع الـ State اللي ممكن تتعامل معاها:

1- Local State

مثل:

- الـ modal مفتوح ولا مقفول
- الـ tab اللي مفتوح
- الفورم فيه error ولا لا

بتستخدم معاه حاجات زي useState, useReducer, أو حتى useRef.

———

2- Global State

ده اللي بيكون مهم لأكثر من component أو حتى أكتر من صفحة.

مثل:

- بيانات المستخدم بعد ما يعمل تسجيل دخول
- اللغة المختارة
- محتوى الـ shopping cart

ممكن تتعامل معاه باستخدام:
Context API | Redux | Zustand | Jotai

———

3- Server State

يعني داتا راجعة من API وبتتغير دايمًا.

مثل:

- قائمة البوستات اللي بترجع
- الإعلانات
- بيانات المنتج

التعامل معاها الأفضل يتم من خلال:

- React Query
- SWR
- custom hooks using fetch

———

4- URL State

ده زي الـ query params والـ path variables.

مثل:

- ?search=react
- /products/123


بتحتاجه لما الصفحة تكون reactive بناءً على URL.

———

💡 إزاي تقرر تستخدم أي نوع منهم؟

اسأل نفسك 3 أسئلة:

1. الداتا دي مين محتاج يشوفها؟

- لو component واحدة تبقى local
- لو أكثر من component أو أكثر من صفحة تبقى global


2. هل الداتا دي راجعة من السيرفر؟

- لو أيوه تبقى server state
- لو لا يبقى ترجع لإجابة السؤال الأول


3. هل محتاج تعمل caching أو refetching؟

- لو أيوه ممكن تستخدم React Query/SWR
- لو لا يبقى الـ useEffect كفاية

———

شوية نصائح من التجربة:

- بلاش تستعجل وتستخدم Redux، كتير بيستخدموه في حاجات صغيرة جدًا ممكن تتحل بـ Context أو حتى props.

- خلي الداتا اللي بتتغير كتير تفضل على السيرفر، وخلي الـ React Query تمسكها بدل ما تعملها global state manually.

- متخليش كل حاجة global، ده بيخلي الـ re-rendering يزيد والـ debugging بيكون أصعب.

- الـ Server State مش دايمًا محتاج يتحول لـ Global State، الـ React Query مثلًا بيخزنها وبيشاركها بين الـ components تلقائي، من غير ما تدخلها في Redux أو غيره.

- الـ Context ممتاز للحاجات اللي مش بتتغير كتير، زي الـ theme أو اللغة أو المستخدم اللي دخل مرة واحدة وخلاص.

———

اختيارك للـ state له تأثير مباشر على الـ performance، وكمان الـ maintainability، والـ DX بتاعك.

———

وفقكم الله لكل خير 🌿

BY DevGuide 🇵🇸


Warning: Undefined variable $i in /var/www/tg-me/post.php on line 283

Share with your friend now:
tg-me.com/the_developer_guide/5316

View MORE
Open in Telegram


DevGuide 🇵🇸 Telegram | DID YOU KNOW?

Date: |

Spiking bond yields driving sharp losses in tech stocks

A spike in interest rates since the start of the year has accelerated a rotation out of high-growth technology stocks and into value stocks poised to benefit from a reopening of the economy. The Nasdaq has fallen more than 10% over the past month as the Dow has soared to record highs, with a spike in the 10-year US Treasury yield acting as the main catalyst. It recently surged to a cycle high of more than 1.60% after starting the year below 1%. But according to Jim Paulsen, the Leuthold Group's chief investment strategist, rising interest rates do not represent a long-term threat to the stock market. Paulsen expects the 10-year yield to cross 2% by the end of the year. A spike in interest rates and its impact on the stock market depends on the economic backdrop, according to Paulsen. Rising interest rates amid a strengthening economy "may prove no challenge at all for stocks," Paulsen said.

That strategy is the acquisition of a value-priced company by a growth company. Using the growth company's higher-priced stock for the acquisition can produce outsized revenue and earnings growth. Even better is the use of cash, particularly in a growth period when financial aggressiveness is accepted and even positively viewed.he key public rationale behind this strategy is synergy - the 1+1=3 view. In many cases, synergy does occur and is valuable. However, in other cases, particularly as the strategy gains popularity, it doesn't. Joining two different organizations, workforces and cultures is a challenge. Simply putting two separate organizations together necessarily creates disruptions and conflicts that can undermine both operations.

DevGuide 🇵🇸 from hk


Telegram DevGuide 🇵🇸
FROM USA